// pages/shoplist/index.js
Page({

  /**
   * 页面的初始数据
   */
  data: {
    // 设置初始数据
    query:{},
    // 商铺的信息
    shopList:[],
    // 请求的页数
    page:1,
    // 每一页请求的数量
    pageSize:10,
    // 总共的页数
    total:0,
    // 定义节流阀
    isLoading:false
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
    // 转存接收到的参数
    this.setData({
      query:options
    }),
    // 调用请求数据的接口
    this.getShopList()
  },
// 获取商铺的数据的接口
getShopList(cb){
  this.setData({
    isLoading:true
  })
  // 展示loading效果
  wx.showLoading({
    title: '数据加载中...',
  })
  wx.request({
    url: `https://applet-base-api-t.itheima.net/categories/${this.data.query.id}/shops`,
    method:"GET",
    data:{
      _page:this.data.page,
      _limit:this.data.pageSize
    },
    success:(res)=>{
      this.setData({
        shopList:[...this.data.shopList,...res.data],
        total:res.header['X-Total-Count'] - 0 //获取到的是一个字符串-0可以强制转换为数字
      })
    },
    complete:()=>{
      // 隐藏loading效果
      wx.hideLoading()
      // 更改节流阀的状态
      this.setData({
        isLoading:false
      })
      // 关闭下拉刷新点窗口
      // wx.stopPullDownRefresh()
      cb && cb()
    }
  })
},


  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {
    wx.setNavigationBarTitle({
      // 动态设置标题
      title: this.data.query.title
    })
  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {
    // 需要重置关键的数据
    this.setData({
      page:1,
      shopList:[],
      totla:0
    })
    // 重新发起数据请求
    this.getShopList(()=>{
       // 关闭下拉刷新点窗口
      wx.stopPullDownRefresh()
    })
  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {
    // 判断数据后面还有没有
    if(this.data.page*this.data.pageSize >=this.data.total){
      // 证明没有下一页的数据了
      return wx.showToast({
        title: '数据加载完毕',
        icon:"none"
      })
    }
    // 判断当前是否处于加载中
    if(this.data.isLoading) return
    // 触底时调用获取列表的方法
    this.setData({
      page:this.data.page + 1
    })
    this.getShopList()
  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  }
})